**CS2100 Computer Organisation**

**Tutorial #8: MSI Components**

**Answers**

# ***LumiNUS Discussion Questions:***

These questions will not be discussed in tutorial. Please discuss on the forum.

D1. Given this Boolean function:

***F*(*A,B,C*) =  *m*(1, 2, 3)**

We want to implement this function using a **3×8 decoder** **with normal outputs** as shown below. Point out the mistakes in the solution below.

0

1

2

3

4

5

6

7

**3×8 DEC**

*A*

*B*

*C* (MSB)

*A*

*B*

*C*

*F*

0

0

0

0

0

*C*

*B*

*A*

Answers:

* Inputs *A*, *B*, *C* should be connected to selector inputs *C*, *B*, *A* respectively.
* Unused outputs of the decoder should not be labelled as 0. Leave them unused.

D2. Given the following circuit comprising a **3×8 decoder with negated outputs** and a **2×4 decoder with normal outputs**, what is the Boolean function *G*(*X,Y,Z*)?

0

1

2

3

4

5

6

7

**3×8 DEC**

*S*2

*S*1

*S*0

*X*

*Y*

*Z*

0

1

2

3

**2×4 DEC**

*S*1

*S*0

*G*

*m2'*

*G* =(*m2'*)*'*∙(*m5'*)*'* + (*m2'*)*'*∙(*m5'*)

= (*m2'*)*'* = *m2*

*m5'*

How would you label these two intermediate outputs? (Use minterm or maxterm notation.)

Answer: ***G*(*X*,*Y*,*Z*) *= X'*∙*Y*∙*Z'***

D3. Given the following circuit comprising a **one-enabled** **2×4 decoder with normal outputs**, what is the simplified SOP expression of Boolean function *H(A,B,C)*?

*A*

*B*

0

1

2

3

**2×4 DEC**

*S*1

*S*0

*H*

*C*

*E*

*C*∙(*A'*)*'*∙*B*

Answer: ***H*(*A,B,C*) *= B' + C*∙*A*∙*B = B' + A*∙*C***

# ***Tutorial Questions:***

1. Realize the following function with (a) **an 8:1 multiplexer**, and (b) **a 4:1 multiplexer** using the first 2 input variables as the selector inputs.

***F*(*X, Y, Z*) = *M*(1, 5, 6) ⋅ *D*(4)**

You may write complemented variables instead of drawing an inverter to derive it. If you have several choices for your answer, choose the simplest one (constant logic values 0 and 1 are simpler than literals). You may write “x” or “d” for “don’t-care” values.

What if we use the last 2 input variables as the selector inputs instead for the 4:1 multiplexer?

Answers:

*F* is a 3-variable function, so there are 23 = 8 rows in its truth table. Using an 8:1 multiplexer, we do not need to collapse any input; we just copy the values of *F* directly to the multiplexer inputs:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| X | *Y* | *Z* | *F* | *F* |
| 0 | 0 | 0 | 1 | ***Z'*** |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | **1** |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | d | **0 / *Z'*** |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 | ***Z*** |
| 1 | 1 | 1 | 1 |

2

***F***

1

**0**

**1**

**1**

**d**

**0**

**0**

1

0

1

2

3

4

5

6

7

1

0

***X***

***Y***

***Z***

8:1

MUX

4:1

MUX

1

0

0

1

2

3

***X***

***Y***

***Z'***

1

**0/*Z'***

*Z*

***F***

To use a 4:1 multiplexer, we need to collapse the 8-row truth table to a 4-row table of multiplexer inputs (see table above). For simplicity sake, we choose the most significant variables as our selector lines (unless the instruction says otherwise), and the least significant variable as the input variable into the multiplexer.

Given that the maxterms are *M*1, *M*5 and *M*6 (where *F* is false), we put “0” in the inputs 1, 5 and 6 of the 8:1 multiplexer. How do we deal with the don’t-care at *M*4 (or *m*4)? Since it is a don’t-care input, we can put a **“0”** or **“1”** or **“d”** (I’m avoiding “X” because “X” happens to be one of the three variables). Since we are going to collapse inputs, we put a “d” to preserve its don’t-care state. The collapse works likewise except that we need to deal with the “d”. Indeed, there is no fast way to decide whether “d” should be “0” or “1” in order to get the most simplified circuit. However, there is a good heuristic – we let “d” be the same as the other input in that same group. In this case, since input line 5 is a “0”, we make the don’t-care at input line 4 “0” as well. Doing so will make the design less complicated. (If we make the don’t-care “1”, then the third multiplexer input would be *Z'* instead of 0.) In my solution above, I list out both answers 0 and *Z'* for the third multiplexer input, but the question asks for the simplest one, so students should give “0”. Can we write “d” for the third input? No, because if we write “d”, it means that 1 is also a possible answer for the third multiplexer input.

(If time permits, show students how to do the 4:1 multiplexer if the last two variables, i.e. *Y* and *Z*, instead are chosen for the multiplexer selector lines.)

2. You are given the following Boolean function: ***K(W,X,Y,Z)* = *m*(8, 11)**.

You are to implement this function using the fewest number of one-enabled 2×4 decoder with normal outputs and at most one logic gate? (Logic gates, as you have learned, are NOT, AND, OR, NAND, NOR, XOR, and XNOR.)

The following is one solution. Is there a simpler circuit using just one decoder and one logic gate?

1

K

*W*

*X*

*Y*

*Z*

0

1

2

3

**2×4 DEC**

*S*1

*S*0

*E*

0

1

2

3

**2×4 DEC**

*S*1

*S*0

*E*

Answer: There might be other answers.

0

1

2

3

**2×4 DEC**

*S*1

*S*0

*E*

*Y*

*Z*

*Y'*⋅*Z'* + *Y*⋅*Z*

*X*

*W*

*K*

3. [AY2011/2 Semester 2 Exam question]

You are to design a converter that takes in 4-bit input *ABCD* and generates a 3-bit output *FGH* as shown in Table 1 below.

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| **Input** | | | | **Output** | | |
| ***A*** | ***B*** | ***C*** | ***D*** | ***F*** | ***G*** | ***H*** |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 | 0 | 1 | 0 |
| 1 | 1 | 1 | 0 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 1 | 1 | 0 |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 |

Table 2

|  |  |
| --- | --- |
| ***S*** | ***Y*3*Y*2*Y*1*Y*0** |
| 0 | *J*3*J*2*J*1*J*0 |
| 1 | *K*3*K*2*K*1*K*0 |

Table 1

You are given the following components:

1. A **Count-1** device that takes in a 4-bit input *WXYZ* and generates a 3-bit output *C*2*C*1*C*0 which is the number of 1s in the input. For example, if *WXYZ* = 0111, then *C*2*C*1*C*0 = 011 (or 3).
2. A **Count-0** device that takes in a 4-bit input *WXYZ* and generates a 3-bit output *C*2*C*1*C*0 which is the number of 0s in the input. For example, if *WXYZ* = 0111, then *C*2*C*1*C*0 = 001 (or 1).
3. A **quad 2:1 multiplexer** that takes in two 4-bit inputs *J*3*J*2*J*1*J*0 and *K*3*K*2*K*1*K*0, and directs one of the inputs to its output *Y*3*Y*2*Y*1*Y*0 depending on its control signal *S*, as shown in Table 2 above.
4. A **4-bit parallel adder** that takes in two 4-bit unsigned binary numbers and outputs the sum.

The block diagrams of these components are shown below:

**Count-1**

*W*

*X*

*Y*

*Z*

*C*2

*C*1

*C*0

**Count-0**

*W*

*X*

*Y*

*Z*

*C*2

*C*1

*C*0

**Quad**

**2:1 MUX**

3

2

1

0

*Y*

3

2

1

0

3

2

1

0

*J*

*K*

*S*

**4-bit**

**adder**

3

2

1

0

*S*

3

2

1

0

3

2

1

0

*X*

*Y*

*Cin*

*Cout*

Given the above 4 components, you are to employ block-level design to design the converter, without using any additional logic gate or other devices. You may observe that if *A* = 1, then the output *FGH* is simply the number of 1s in the input *ABCD*. You are to make your own observation for the case when *A* = 0.

[Hint (not given in exam): You need only use one of each of the components. Complete the diagram below.]

Key ideas:

1. If *A* = 1 (or *D* = 0), count #1s in *ABCD*.
2. If *A* = 0 (or *D* = 1), either
   1. #1s + 2 × #0s; or
   2. 4 + #0s

To tutors:

To save time, you may want to project the incomplete diagram on the whiteboard and get student to complete it on the whiteboard.

**Count-0**

*W*

*X*

*Y*

*Z*

*C*2

*C*1

*C*0

**Count-1**

*W*

*X*

*Y*

*Z*

*C*2

*C*1

*C*0

**Quad**

**2:1 MUX**

3

2

1

0

*Y*

3

2

1

0

3

2

1

0

*J*

*K*

*S*

**4-bit**

**adder**

3

2

1

0

*S*

3

2

1

0

3

2

1

0

*X*

*Y*

*Cin*

*Cout*

***A***

***B***

***C***

***D***

**0**

**0**

**0**

***F***

***G***

***H***

**0**

Tutors: Check that all the inputs of the components are connected to some values, not left unconnected. Tell students that in the exam, the incomplete diagram will not be given!

OR

**0**

**1**

**0**

**0**

**Count-0**

*W*

*X*

*Y*

*Z*

*C*2

*C*1

*C*0

**Count-1**

*W*

*X*

*Y*

*Z*

*C*2

*C*1

*C*0

**Quad**

**2:1 MUX**

3

2

1

0

*Y*

3

2

1

0

3

2

1

0

*J*

*K*

*S*

**4-bit**

**adder**

3

2

1

0

*S*

3

2

1

0

3

2

1

0

*X*

*Y*

*Cin*

*Cout*

***A***

***B***

***C***

***D***

**0**

***F***

***G***

***H***

**0**

**0**

4. Implement the following Boolean function using the fewest number of **2×4 decoder with 1-enable and normal outputs**, and at most two logic gates.

*F*(*A,B,C,D*) = *m* (0,1,3,4,6,7,8,9,11,12,14,15)

(There is a solution with two decoders and one logic gate which is easy to obtain. A more challenging solution uses one decoder and two logic gates. We will discuss the former and leave the latter as an exercise for your own attempt.)

Answer:

It is easier to think about implementing *F'* (which is *m*(2,5,10,13) or *b'*⋅*c*⋅*d' + b*⋅*c'*⋅*d*), and then adding an inverter to invert it back to *F*.

**C⋅(B'⋅D')**

**F**

2×4

DEC

*S1*

S0

0

1

2

3

*E*

2×4

DEC

*S1*

S0

0

1

2

3

*E*

***B***

***D***

There are equivalent alternative solutions that rearrange the inputs *B*, *C* and *D*.

Just check that the output is still (*B'*⋅*C*⋅*D' + B*⋅*C'*⋅*D)'.*

***C***

**B⋅(C'⋅D)**

We accept such solution with 2 decoders and one logic gate, but not more. (Note that an inverter, if used, is counted as a logic gate as well.)

There is an even simpler circuit requiring only one decoder and two gates. It was given by a student in a past semester. Not many students might be able to derive it. The following are two such answers. These are only for your reference and you need not present them. You may tell students that such solutions exist and ask them to try on their own.

2×4

DEC

*S1*

S0

0

1

2

3

*E*

F

*C*

*D*

*B*

B'⋅D' + B⋅D

*F* = [ (*B* ☉ *D*)⋅*C'*⋅*D* + (*B* ☉ *D*)⋅*C*⋅*D'* ]'

= [ (*B* ☉ *D*) ⋅ (*C* ⊕ *D*) ]'

= **(*B* ⊕ *D*) + (*C* ☉ *D*)**

Another possible answer from a student:

2×4

DEC

*S1*

S0

0

1

2

3

*E*

F

*C*

*D*

*B*

B'⋅D + B⋅D'

1

C'⋅D'

C⋅D